<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <script src="./libs/jquery-1.12.4.min.js"></script>
    <script src="./libs/template-web.js"></script>
    <!-- 导入bootstrap的js文件 -->
    <script src="./libs/bootstrap/js/bootstrap.min.js"></script>
    <!-- 导入分页导航文件 -->
    <script src="./libs/jquery.twbsPagination.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <form class="form-inline">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <!-- <option value="">所有分类</option>
                            <option>未分类</option>
                            <option>奇趣事</option>
                            <option>会生活</option>
                            <option>爱旅行</option> -->
                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </form>
                </div>
                <div class="col-xs-6">
                    <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <!-- <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
                            <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
                        </td>
                    </tr> -->
                </tbody>

            </table>
            <div class="row text-center">
                <!-- 添加分页导航静态结构 -->
                <ul id="pagination" class="pagination-sm"></ul>
            </div>
        </div>
    </div>

</body>
<!-- 文章分类模板 -->
<script type="text/html" id="sel">
    <option value="">所有分类</option>
    {{each data}}
    <option value='{{$value.id}}'>{{$value.name}}</option>
    {{/each}}
</script>

<!-- 文章列表模板 -->
<script type="text/html" id="list">
    {{each data}}
    <tr>
        <td>{{$value.title}}</td>
        <td>{{$value.author}}</td>
        <td>{{$value.category}}</td>
        <td class="text-center">{{$value.date}}</td>
        <td class="text-center">{{$value.state}}</td>
        <td class="text-center">
            <a data-id="{{$value.id}}" href="article_edit.html?id={{$value.id}}" class="btn btn-default btn-xs">编辑</a>
            <a data-id="{{$value.id}}" href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
        </td>
    </tr>
    {{/each}}
</script>
<script src="./libs/https.js"></script>
<script>
    $(function () {

        // //1.发起请求获取当前文章列表数据
        $.ajax({
            url: BigNew.category_list,
            success: (res) => {
                if (res.code == 200) {
                    // 根据模板引擎生成字符串
                    let str = template('sel', res);
                    $('#selCategory').html(str);
                }
            }
        })
        // 保存当前页码,默认为1
        let selPage = 1;

        // 获取当前需要的数据
        function getInfo(currentPage, callback) {
            $.ajax({
                url: BigNew.article_query,
                data: {
                    type: $('#selCategory').val(),
                    state: $('#selStatus').val(),
                    page: currentPage,
                    perpage: 10
                },
                success: (res) => {
                    if (res.code == 200) {
                        // 生成模板
                        let str = template('list', res.data);
                        $('tbody').html(str);
                        // 判断是否有回调函数
                        if (callback && res.data.data.length != 0) {
                            // 执行回调函数
                            callback(res);
                            $('#pagination').show(); //显示分页导航
                            $('#tips').hide(); //影藏提示
                        } else if (res.data.data.length == 0 && selPage == 1) {
                            // 当第一也得数据为0时就真的没有数据了,显示提示内容,隐藏分页导航
                            $('#pagination').hide();
                            $('#tips').show();
                        } else if (res.data.data.length == 0 && res.data.totalPage == selPage - 1) {
                            // 最后一页的最后一条数据已经被删除,当前页码减一等于总页数
                            $('#pagination').twbsPagination('changeTotalPages', res.data.totalPage,
                                selPage - 1);
                        }
                    }
                }
            })
        }
        // 第一次请求,设置分页导航
        getInfo(selPage, function (res) {
            $('#pagination').twbsPagination({
                first: '首页',
                prev: '上一页',
                next: '下一页',
                last: '尾页',
                totalPages: res.data.totalPage,
                visiblePages: 10,
                onPageClick: function (event, page) {
                    // 此时将当前页码改变然后渲染页面
                    selPage = page;
                    // 发起第二次请求,加载指定页码
                    getInfo(selPage, null);
                }
            });
        });

        // 第三次请求
        $('#btnSearch').on('click', function (e) {
            e.preventDefault();
            selPage = 1;
            // 默认刷新后的当前页码为1
            getInfo(selPage, function (res) {
                $('#pagination').twbsPagination('changeTotalPages', res.data.totalPage, 1);
            })
        })

        // 删除功能
        $('tbody').on('click', '.delete', function (e) {
            e.preventDefault();
            // 询问用户是否真的删除
            if (confirm('是否真的要删除')) {
                let delId = $(this).attr('data-id');
                $.ajax({
                    url: BigNew.article_delete,
                    type: 'POST',
                    data: {
                        id: delId
                    },
                    success: (res) => {
                        if (res.code == 204) {
                            // 重新渲染页面和分页导航
                            getInfo(selPage, function (res) {
                                $('#pagination').twbsPagination('changeTotalPages',
                                    res.data.totalPage, selPage);
                            })
                        }
                    }
                })
            }
        })


        // ----------------
        // //1.发起请求获取当前文章列表数据
        // $.ajax({
        //     url: BigNew.category_list,
        //     success: (res) => {
        //         if (res.code == 200) {
        //             // 根据模板引擎生成字符串
        //             let str = template('sel', res);
        //             $('#selCategory').html(str);
        //         }
        //     }
        // })

        // // 2.发起请求获取文章
        // $.ajax({
        //     url: BigNew.article_query,
        //     data: {
        //         type: $('#selCategory').val(),
        //         state: $('#selStatus').val(),
        //         page: 1,
        //         perpage: 10
        //     },
        //     success: (res) => {
        //         if (res.code == 200) {
        //             let str = template('list', res.data);
        //             $('tbody').html(str);
        //             // 2.1添加分页导航
        //             $('#pagination').twbsPagination({
        //                 first: '首页',
        //                 prev: '上一页',
        //                 next: '下一页',
        //                 last: '尾页',
        //                 totalPages: res.data.totalPage,
        //                 visiblePages: 10,
        //                 onPageClick: function (event, page) {
        //                     console.log(page);
        //                     // 当点击的时候需要再次发起aja请求渲染页面
        //                     $.ajax({
        //                         url: BigNew.article_query,
        //                         data: {
        //                             type: $('#selCategory').val(),
        //                             state: $('#selStatus').val(),
        //                             page,
        //                             perpage: 10
        //                         },
        //                         success: (res) => {
        //                             if (res.code == 200) {
        //                                 let str = template('list', res
        //                                     .data);
        //                                 // 渲染页面
        //                                 $('tbody').html(str);
        //                             }
        //                         }
        //                     })
        //                 }
        //             });
        //         }
        //     }
        // })

        // // 3.筛选按钮功能
        // $('#btnSearch').on('click', function (e) {
        //     e.preventDefault();
        //     $.ajax({
        //         url: BigNew.article_query,
        //         data: {
        //             type: $('#selCategory').val(),
        //             state: $('#selStatus').val(),
        //             page: 1,
        //             perpage: 10
        //         },
        //         success: (res) => {
        //             if (res.code == 200) {
        //                 let str = template('list', res.data);
        //                 $('tbody').html(str);
        //                 // 当切换页面时再次调用
        //                 $('#pagination').twbsPagination('changeTotalPages', res.data
        //                     .totalPage, 1);
        //             }
        //         }
        //     })
        // })


    })
</script>

</html>